Make CASSERT() macro callable from anywhere
authorSandrine Bailleux <[email protected]>
Wed, 14 Oct 2015 15:00:23 +0000 (16:00 +0100)
committerSandrine Bailleux <[email protected]>
Mon, 19 Oct 2015 07:52:35 +0000 (08:52 +0100)
The CASSERT() macro introduces a typedef for the sole purpose of
triggering a compilation error if the condition to check is false.
This typedef is not used afterwards. As a consequence, when the
CASSERT() macro is called from withing a function block, the compiler
complains and outputs the following error message:

  error: typedef 'msg' locally defined but not used [-Werror=unused-local-typedefs]

This patch adds the "unused" attribute for the aforementioned
typedef. This silences the compiler warning and thus makes the
CASSERT() macro callable from within function blocks as well.

Change-Id: Ie36b58fcddae01a21584c48bb6ef43ec85590479

include/lib/cassert.h

index 0e5529dd6ab0667a0c29b1515220f6335a03a748..e8089cbbe1ac5555855cdf56c8a9c946640568dc 100644 (file)
 /*******************************************************************************
  * Macro to flag a compile time assertion. It uses the preprocessor to generate
  * an invalid C construct if 'cond' evaluates to false.
- * The following  compilation error is triggered if the assertion fails:
+ * The following compilation error is triggered if the assertion fails:
  * "error: size of array 'msg' is negative"
+ * The 'unused' attribute ensures that the unused typedef does not emit a
+ * compiler warning.
  ******************************************************************************/
-#define CASSERT(cond, msg)     typedef char msg[(cond) ? 1 : -1]
+#define CASSERT(cond, msg)     \
+       typedef char msg[(cond) ? 1 : -1] __attribute__((unused))
 
 #endif /* __CASSERT_H__ */